## CSCI 210: Computer Architecture Lecture 30: Pipelining the Datapath

Stephen Checkoway Oberlin College May 6, 2022 Slides from Cynthia Taylor

#### Announcements

• Problem Set 10 due a week from today

• Lab 8 due Sunday

• Office Hours Friday 13:30 – 14:30

## **Pipeline registers**

• Need registers between stages

To hold information produced in previous cycle



#### WB for Store

SW



#### **Pipeline Stages**

Should we force every instruction to go through all 5 stages? Can we break it up, with R-type taking 4 cycles instead of 5?

| Selection | Yes/No | <b>Reason (Choose BEST answer)</b>                                         |  |  |  |  |
|-----------|--------|----------------------------------------------------------------------------|--|--|--|--|
| А         | Yes    | Decreasing R-type to 4 cycles improves instruction throughput              |  |  |  |  |
| В         | Yes    | Decreasing R-type to 4 cycles improves instruction latency                 |  |  |  |  |
| С         | No     | Decreasing R-type to 4 cycles causes hazards                               |  |  |  |  |
| D         | No     | Decreasing R-type to 4 cycles causes hazards and doesn't impact throughput |  |  |  |  |
| E         | No     | Decreasing R-type to 4 cycles causes hazards and doesn't impact latency    |  |  |  |  |

#### Mixed Instructions in the Pipeline



## State of pipeline in a given cycle



## **Pipelined Control**



## How do we control our pipelined CPU?

A. We need to add new control signals.

B. We need to forward the control values to the correct stage.

C. We don't need to do anything special; it will work the way it is.

## **Pipeline Control**

• IF Stage: read Instr Memory (always) and write PC (on System Clock)

• ID Stage: no optional control signals to set

EX, MEM, and WB stages have control signals
The pipeline registers will need to store the control signals

## **Pipelined Control**

#### Control signals derived from instruction







|     | EX Stage |        |        |        | MEM Stage |         |          | WB Stage |           |
|-----|----------|--------|--------|--------|-----------|---------|----------|----------|-----------|
|     | RegDst   | ALUOp1 | ALUOp0 | ALUSrc | Brch      | MemRead | MemWrite | RegWrite | Mem toReg |
| R   | 1        | 1      | 0      | 0      | 0         | 0       | 0        | 1        | 0         |
| lw  | 0        | 0      | 0      | 1      | 0         | 1       | 0        | 1        | 1         |
| SW  | Х        | 0      | 0      | 1      | 0         | 0       | 1        | 0        | Х         |
| beq | Х        | 0      | 1      | 0      | 1         | 0       | 0        | 0        | Х         |

#### **Dependencies & Forwarding**



## We can BEST solve these data hazards

- A. By stalling.
- B. By forwarding.
- C. By combining forwards and stalls.
- D. By doing something else.

![](_page_14_Figure_5.jpeg)

# Reading

- Next lecture: Data Hazards
  - Section 5.8